<template>
    <div class="default-main ba-table-box">
        <el-alert class="ba-table-alert" v-if="baTable.table.remark" :title="baTable.table.remark" type="info" show-icon />

        <!-- 表格顶部菜单 -->
        <!-- 自定义按钮请使用插槽，甚至公共搜索也可以使用具名插槽渲染，参见文档 -->
        <TableHeader
            :buttons="['refresh', 'add', 'edit', 'delete', 'comSearch', 'quickSearch', 'columnDisplay']"
            :quick-search-placeholder="t('Quick search placeholder', { fields: t('workorder.report.quick Search Fields') })"
        ></TableHeader>

        <!-- 表格 -->
        <!-- 表格列有多种自定义渲染方式，比如自定义组件、具名插槽等，参见文档 -->
        <!-- 要使用 el-table 组件原有的属性，直接加在 Table 标签上即可 -->
        <Table ref="tableRef"></Table>

        <!-- 表单 -->
        <Info />
    </div>
</template>

<script setup lang="ts">
import { onMounted, provide, ref } from 'vue'
import { useI18n } from 'vue-i18n'
import Info from './info.vue'
import { baTableApi } from '/@/api/common'
import { defaultOptButtons } from '/@/components/table'
import TableHeader from '/@/components/table/header/index.vue'
import Table from '/@/components/table/index.vue'
import baTableClass from '/@/utils/baTable'
import { cloneDeep } from 'lodash-es'
import { buildJsonToElTreeData } from '/@/utils/common'

defineOptions({
    name: 'workorder/report',
})

const { t } = useI18n()
const tableRef = ref()
let optButtons: OptButton[] = [
    {
        render: 'tipButton',
        name: 'info',
        title: 'Info',
        text: '',
        type: 'primary',
        icon: 'fa fa-search-plus',
        class: 'table-row-edit',
        disabledTip: false,
        click: (row: TableRow) => {
            infoButtonClick(row)
            baTable.table.extend!.infoId = row.id
        },
    }
]

/**
 * baTable 内包含了表格的所有数据且数据具备响应性，然后通过 provide 注入给了后代组件
 */
const baTable = new baTableClass(
    new baTableApi('/admin/workorder.Report/'),
    {
        pk: 'id',
        column: [
            { type: 'selection', align: 'center', operator: false },
            { label: t('workorder.report.id'), prop: 'id', align: 'center', width: 70, operator: 'RANGE', sortable: 'custom' },
            { label: '案件名称', prop: 'wo.title', align: 'center', operatorPlaceholder: t('Fuzzy query'), operator: 'LIKE' },
            { label: '工程师', prop: 'user.nickname', align: 'center', operatorPlaceholder: t('Fuzzy query'), render: 'tags', operator: 'LIKE' },
            { label: '单位', prop: 'company.name', align: 'center', operatorPlaceholder: t('Fuzzy query'), render: 'tags', operator: 'LIKE' },
            { 
                label: t('workorder.report.status'), 
                prop: 'status', 
                align: 'center', 
                operator: 'eq', 
                render: 'tag',
                sortable: false, 
                replaceValue: { 4: '驳回', 0: '待审核', 1: '通过', 2: '已生成', 3: '已发送' } 
            },
            { label: t('workorder.report.update_time'), prop: 'update_time', align: 'center', render: 'datetime', operator: 'RANGE', sortable: 'custom', width: 160, timeFormat: 'yyyy-mm-dd hh:MM:ss' },
            { label: t('workorder.report.create_time'), prop: 'create_time', align: 'center', render: 'datetime', operator: 'RANGE', sortable: 'custom', width: 160, timeFormat: 'yyyy-mm-dd hh:MM:ss' },
            { label: t('Operate'), align: 'center', width: 140, render: 'buttons', buttons: optButtons, operator: false },
        ],
        dblClickNotEditColumn: [undefined],
        defaultOrder: { prop: 'create_time', order: 'desc' },
    },
    {
        defaultItems: { status: 1, company_id: null },
    }
)

provide('baTable', baTable)

/** 点击查看详情按钮响应 */
const infoButtonClick = (row: TableRow) => {
    if (!row) return
    // 数据来自表格数据,未重新请求api,深克隆,不然可能会影响表格
    let rowClone = cloneDeep(row)
    rowClone.data1 = rowClone.data1 ? [{ label: '点击展开', children: buildJsonToElTreeData(JSON.parse(rowClone.data1)) }] : []
    rowClone.data2 = rowClone.data2 ? [{ label: '点击展开', children: buildJsonToElTreeData(JSON.parse(rowClone.data2)) }] : []
    rowClone.data3 = rowClone.data3 ? [{ label: '点击展开', children: buildJsonToElTreeData(JSON.parse(rowClone.data3)) }] : []
    baTable.form.extend!['info'] = rowClone
    baTable.form.operate = 'Info'
}

onMounted(() => {
    baTable.table.ref = tableRef.value
    baTable.mount()
    baTable.getIndex()?.then(() => {
        baTable.initSort()
        baTable.dragSort()
    })
})
</script>

<style scoped lang="scss"></style>
